import audio

RATE = 8192

# Initialise les trucs liés à l'audio
audio.setrate(3)
audio.setoutgain(100)	# pour le haut-parleur

play = audio.write

def samp(n):
	savegain = audio.getoutgain()
	try:
		audio.setoutgain(0)
		x = raw_input('Appuyez sur Entrée pour échantillonner pendant ' + `n` + ' secondes : ')
		return audio.read(n*RATE)
	finally:
		audio.setoutgain(savegain)

def echo(s, delay, gain):
	return s[:delay] + audio.add(s[delay:], audio.amplify(s, gain, gain))

def save(s, file):
	f = open(file, 'w')
	f.write(s)

def load(file):
	return loadfp(open(file, 'r'))

def loadfp(fp):
	s = ''
	while 1:
		buf = fp.read(16*1024)
		if not buf: break
		s = s + buf
	return s

def unbias(s):
	if not s: return s
	a = audio.chr2num(s)
	sum = 0
	for i in a: sum = sum + i
	bias = (sum + len(a)/2) / len(a)
	print 'Valeur du biais :', bias
	if bias:
		for i in range(len(a)):
			a[i] = a[i] - bias
		s = audio.num2chr(a)
	return s

# Étire le son par un facteur de a/b.
# Considérez cette opération comme le passage d'un taux d'échantillonage
# de a échantillons/seconde à un taux de b échantillons/seconde. Autrement
# dit, si l'entrée fait a octets, la sortie fera b octets.
#
def stretch(s, a, b):
	y = audio.chr2num(s)
	m = len(y)
	out = []
	n = m * b / a
	# i, j traversent y et out (étape 1)
	# ib et ja représentent i*b et j*a; ils sont maintenus aussi proches
	# l'un de l'autre que possible
	i, ib = 0, 0
	j, ja = 0, 0
	for j in range(n):
		ja = ja+a
		while ib < ja:
			i = i+1
			ib = ib+b
		if i >= m:
			break
		if ib = ja:
			out.append(y[i])
		else:
			out.append((y[i]*(ja-(ib-b)) + y[i-1]*(ib-ja)) / b)
	return audio.num2chr(out)

def sinus(freq): # renvoie une onde sinusoïdale d'une seconde
	from math import sin, pi
	factor = 2.0*pi*float(freq)/float(RATE)
	list = range(RATE)
	for i in list:
		list[i] = int(sin(float(i) * factor) * 127.0)
	return audio.num2chr(list)

def softclip(s):
	if '\177' not in s and '\200' not in s:
		return s
	num = audio.chr2num(s)
	extremes = (-128, 127)
	for i in range(1, len(num)-1):
		if num[i] in extremes:
			num[i] = (num[i-1] + num[i+1]) / 2
	return audio.num2chr(num)

def demo():
	gday = load('gday')[1000:6000]
	save(gday, 'gday0')
	gg = [gday]
	for i in range(1, 10):
		for g in gg: play(g)
		g = stretch(gday, 10, 10-i)
		save(g, 'gday' + `i`)
		gg.append(g)
	while 1:
		for g in gg: play(g)
